{% extends 'web/layout/basic.html' %}
{% load static %}

{% block title %}
    SMS LOGIN
{% endblock %}

{% block css %}
    <link rel="stylesheet" href="{% static 'web/css/account/register.css' %}">
{% endblock %}

{% block content %}
    <div class="account">
        <div class="title">手机验证码登录</div>
        <form id="smsLoginForm" method="post" novalidate>
            {% csrf_token %}
            {% for field in sms_login_form %}
                {% if field.name == 'code' %}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        <div class="clearfix">
                            <div class="col-md-7" style="padding-left: 0">
                                {{ field }}
                                <span class="error-msg"></span>
                            </div>
                            <div class="col-md-5">
                                <input id="btnSms" type="button" class="btn btn-default" value="获取验证码">
                            </div>
                        </div>
                    </div>
                {% else %}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        {{ field }}
                        <span class="error-msg"></span>
                    </div>
                {% endif %}
            {% endfor %}
            <div>
                <div style="float: right;">
                    <a href="{% url 'login' %}">用户名密码登录?</a>
                </div>
            </div>
            <input type="button" class="btn btn-primary" id="btnSubmit" value="登 录">
        </form>
    </div>
{% endblock %}

{% block js %}
    <script>
        // 页面加载完成后自动执行函数
        $(function () {
            bindClickBtnSms();
            bindClickSubmit();
        })

        /*
        点击提交（验证码登录）
        */
        function bindClickSubmit() {
            $('#btnSubmit').click(function () {
                $('.error-msg').empty();
                // 收集表单中的数据（找到每一个字段）$('#regForm').serialize()
                // 数据ajax发送到后台
                $.ajax({
                    url: "{% url 'login_sms' %}",
                    type: "POST",
                    data: $('#smsLoginForm').serialize(), // 所有字段数据 + csrf token
                    dataType: "JSON",
                    success: function (res) {
                        if (res.status) {
                            location.href = res.data;
                            console.log(res);
                        } else {
                            $.each(res.error, function (key, value) {
                                $("#id_" + key).next().text(value[0]);
                            })
                        }
                    }
                })
            })
        }

        /*
        点击获取验证码的按钮绑定事件
        */
        function bindClickBtnSms() {
            $('#btnSms').click(function () {
                // 清空error-msg的内容
                $('.error-msg').empty();
                // 获取用户输入的手机号
                // 找到输入框的ID，根据ID获取值，odelForm自动为表单生成id, 格式为id_name
                var mobilePhone = $('#id_mobile_phone').val();
                // 发送ajax请求
                $.ajax({
                        url: "{% url 'send_sms' %}",
                        type: 'GET',
                        data: {mobile_phone: mobilePhone, tpl: 'login'},
                        dataType: "JSON", // 将服务端返回的数据（json字符串）反序列化为对象
                        success: function (resp) {
                            // ajax请求发送成功之后，自动执行的函数； resp就是后端返回的值
                            if (resp.status) {
                                sendSmsRemind();
                            } else {
                                // 错误信息
                                // console.log(res); // {status:False, error:{ mobile_phone: ["错误信息"，],code: ["错误信息"，] }  }
                                $.each(resp.error, function (key, value) {
                                    $("#id_" + key).next().text(value[0]);
                                })
                            }
                        }
                    }
                )
            })
        }

        /*
        倒计时
         */
        function sendSmsRemind() {
            var $smsBtn = $('#btnSms');
            $smsBtn.prop('disabled', true); // 禁用
            var time = 60;
            var remind = setInterval(function () {
                $smsBtn.val(time + '秒重新发送');
                time = time - 1;
                if (time < 1) {
                    clearInterval(remind);
                    $smsBtn.val('点击获取验证码').prop('disabled', false);
                }
            }, 1000)

        }

    </script>
{% endblock %}